<template>
  <a-card :bordered="false">
    <a-spin :spinning="loading">
      <div
        v-if="hasPerm('sysApp:page')"
        class="table-page-search-wrapper"
      >
        <a-form layout="inline">
          <a-row :gutter="48">
            <a-col
              :md="8"
              :sm="24"
            >
              <a-form-item label="应用名称">
                <a-input
                  v-model="queryParam.name"
                  allow-clear
                  placeholder="请输入应用名称"
                />
              </a-form-item>
            </a-col>
            <a-col
              :md="8"
              :sm="24"
            >
              <a-form-item label="唯一编码">
                <a-input
                  v-model="queryParam.code"
                  allow-clear
                  placeholder="请输入唯一编码"
                />
              </a-form-item>
            </a-col>
            <a-col
              :md="8"
              :sm="24"
            >
              <span class="table-page-search-submitButtons">
                <a-button
                  type="primary"
                  @click="$refs.table.refresh(true)"
                >查询</a-button>
                <a-button
                  style="margin-left: 8px"
                  @click="() => queryParam = {}"
                >重置</a-button>
              </span>
            </a-col>
          </a-row>
        </a-form>
      </div>

      <div
        v-if="hasPerm('sysApp:add')"
        class="table-operator"
      >
        <a-button
          v-if="hasPerm('sysApp:add')"
          type="primary"
          icon="plus"
          @click="$refs.addForm.add()"
        >
          新增应用
        </a-button>
      </div>

      <s-table
        ref="table"
        size="default"
        :columns="columns"
        :data="loadData"
        :alert="true"
        :row-key="(record) => record.id"
        :row-selection="{ selectedRowKeys: selectedRowKeys, onChange: onChange }"
      >
        <span
          slot="active"
          slot-scope="text"
        >
          {{ activeFilter(text) }}
        </span>
        <span
          slot="status"
          slot-scope="text"
        >
          {{ statusFilter(text) }}
        </span>

        <span
          slot="action"
          slot-scope="text, record"
        >
          <a
            v-if="hasPerm('sysApp:edit')"
            @click="$refs.editForm.edit(record)"
          >编辑</a>
          <a-divider
            v-if="hasPerm('sysApp:edit') & hasPerm('sysApp:delete')"
            type="vertical"
          />
          <a-popconfirm
            v-if="hasPerm('sysApp:delete')"
            placement="topRight"
            title="确认删除？"
            @confirm="() => sysAppDelete(record)"
          >
            <a>删除</a>
          </a-popconfirm>

          <a-divider
            v-if="hasPerm('sysApp:setAsDefault') & hasPerm('sysApp:delete') & record.active == 'N' || hasPerm('sysApp:edit') & hasPerm('sysApp:setAsDefault') & record.active == 'N'"
            type="vertical"
          />

          <a-popconfirm
            v-if="hasPerm('sysApp:setAsDefault') & record.active == 'N'"
            placement="topRight"
            title="设置为默认应用？"
            @confirm="() => sysDefault(record)"
          >
            <a>设为默认</a>
          </a-popconfirm>

        </span>
      </s-table>

      <add-form
        ref="addForm"
        @ok="handleOk"
      />
      <edit-form
        ref="editForm"
        @ok="handleOk"
      />
    </a-spin>
  </a-card>
</template>

<script>
  import { STable } from '@/components'
  import { getAppPage,sysAppDelete ,sysAppSetAsDefault} from '@/api/modular/system/appManage'
  import { sysDictTypeDropDown } from '@/api/modular/system/dictManage'
  import editForm from './editForm'
  import addForm from './addForm'

  export default {
    components: {
      STable,
      editForm,
      addForm
    },
    data () {
      return {
        //description: '面包屑说明',
        labelCol: {
          xs: { span: 24 },
          sm: { span: 5 }
        },
        wrapperCol: {
          xs: { span: 24 },
          sm: { span: 16 }
        },
        // 查询参数
        queryParam: {},
        // 表头
        columns: [
          {
            title: '应用名称',
            dataIndex: 'name'
          },
          {
            title: '唯一编码',
            dataIndex: 'code'
          },
          {
            title: '是否默认',
            dataIndex: 'active',
            scopedSlots: { customRender: 'active' }
          },
          {
            title: '状态',
            dataIndex: 'status',
            scopedSlots: { customRender: 'status' }
          }
        ],
        // 加载数据方法 必须为 Promise 对象
        loadData: parameter => {
          return getAppPage(Object.assign(parameter, this.queryParam)).then((res)=>{
            return res.data
          })
        },
        loading:false,
        selectedRowKeys: [],
        selectedRows: [],
        statusDict:[],
        activeDict:[],
      }
    },

    created(){
      this.sysDictTypeDropDown()
      if(this.hasPerm('sysApp:edit') || this.hasPerm('sysApp:delete') || this.hasPerm('sysApp:setAsDefault')){
        this.columns.push({
          title: '操作',
          width: '200px',
          dataIndex: 'action',
          scopedSlots: { customRender: 'action' }
        })
      }
    },

    methods: {
      activeFilter (active) {
        const active_value = this.activeDict.filter(item => item.code == active)
        if(active_value.length>0){
          return active_value[0].value
        }
      },
      statusFilter (status) {
        const status_value = this.statusDict.filter(item => item.code == status)
        if(status_value.length>0){
          return status_value[0].value
        }
      },

      /**
       * 获取字典数据
       */
      sysDictTypeDropDown(){
        sysDictTypeDropDown({code:'yes_or_no'}).then((res)=>{
          this.activeDict=res.data
        })
        sysDictTypeDropDown({code:'common_status'}).then((res)=>{
          this.statusDict=res.data
        })
      },

      handleOk () {
        this.$refs.table.refresh()
      },

      sysDefault(record){
        this.loading=true
        sysAppSetAsDefault({id:record.id}).then((res)=>{
          this.loading=false
           if(res.success){
             this.$message.success('设置成功')
             this.$refs.table.refresh()
           }else{
             this.$message.error('设置失败：'+res.message)
           }
        })
      },
      /**
       * 删除应用
       */
      sysAppDelete(record){
        this.loading=true
        sysAppDelete(record).then((res)=>{
          this.loading=false
          if(res.success) {
            this.$message.success('删除成功')
            this.$refs.table.refresh()
          }else{
            this.$message.error('删除失败：'+res.message)
          }
        }).catch((err)=>{
          this.$message.error('删除错误：'+err.message)
        })
      },
      onChange (selectedRowKeys, selectedRows) {
        this.selectedRowKeys = selectedRowKeys
        this.selectedRows = selectedRows
      },
    },
  }
</script>
<style scoped>

  .table-operator {
    margin-bottom: 18px;
  }
  button {
    margin-right: 8px;
  }

</style>